/**
 * 新增修改完成调用 modalFormOk方法 编辑弹框组件ref定义为modalForm
 * 高级查询按钮调用 superQuery方法  高级查询组件ref定义为superQueryModal
 * data中url定义 list为查询列表  delete为删除单条记录  deleteBatch为批量删除
 */
import { filterObj } from '@/utils/util';
import { deleteAction, getAction, downFile, getFileAccessHttpUrl, postAction } from '@/api/manage'
import Vue from 'vue'
import { ACCESS_TOKEN, TENANT_ID } from "@/store/mutation-types"
import store from '@/store'
import { mapGetters, mapMutations } from 'vuex'
export const JeecgListMixin = {
  data() {
    return {
      /* 查询条件-请不要在queryParam中声明非字符串值的属性 */
      queryParam: {},
      /* 数据源 */
      dataSource: [],
      /* 分页参数 */
      ipagination: {
        current: 1,
        pageSize: 10,
        pageSizeOptions: ['10', '20', '30'],
        showTotal: (total, range) => {
          return range[0] + "-" + range[1] + " 共" + total + "条"
        },
        showQuickJumper: true,
        showSizeChanger: true,
        total: 0
      },
      /* 排序参数 */
      isorter: {
        column: 'createTime',
        order: 'desc',
      },
      /* 筛选参数 */
      filters: {},
      /* table加载状态 */
      loading: false,
      /* table选中keys*/
      selectedRowKeys: [],
      /* table选中records*/
      selectionRows: [],
      /* 查询折叠 */
      toggleSearchStatus: false,
      /* 高级查询条件生效状态 */
      superQueryFlag: false,
      /* 高级查询条件 */
      superQueryParams: '',
      /** 高级查询拼接方式 */
      superQueryMatchType: 'and',
    }
  },
  created() {
    console.log('js');
    // crm跳转过来需要携带协议类型
    if (this.fromcrm.contarctType) {
      this.queryParam.contractType = this.fromcrm.contarctType
      this.queryParam.partnerName = this.fromcrm.partnerName
      this.SET_NULL_CRM()
    }
    if (!this.disableMixinCreated) {
      console.log(' -- mixin created -- ', this.$route)
      if (this.$route.name == 'emp-EmpIncomeList') {
        // 如果当前页面为月度详情页面时 并且 有城市id 团队id时， 不请求列表数据
        if (!(this.$route.query.cityId || this.$route.query.teamId)) {
          this.loadData();
        }
      } else if (this.$route.name == 'emp-EmpIncomeCityList') {
        // 如果当前页面为月度城市页面时 并且 有团队id时， 不请求列表数据
        if (!this.$route.query.teamId) {
          this.loadData();
        }
      } else {
        this.loadData();
      }
      //初始化字典配置 在自己页面定义
      this.initDictConfig();
    }
  },
  computed: {
    ...mapGetters(['fromcrm']),
    //token header
    tokenHeader() {
      let head = { 'X-Access-Token': Vue.ls.get(ACCESS_TOKEN) }
      let tenantid = Vue.ls.get(TENANT_ID)
      if (tenantid) {
        head['tenant-id'] = tenantid
      }
      return head;
    }
  },
  methods: {
    ...mapMutations(['SET_NULL_CRM']),
    loadData(arg) {
      if (!this.url.list) {
        this.$message.error("请设置url.list属性!")
        return
      }
      //加载数据 若传入参数1则加载第一页的内容
      if (arg === 1) {
        this.ipagination.current = 1;
      }
      var params = this.getQueryParams();//查询条件
      this.loading = true;
      console.log('?????/??????');
      console.log(params);

      getAction(this.url.list, params).then((res) => {
        if (res.success) {
          //update-begin---author:zhangyafei    Date:20201118  for：适配不分页的数据列表------------
          this.dataSource = res.result.records || res.result;
          if (res.result.total) {
            this.ipagination.total = res.result.total;
          } else {
            this.ipagination.total = 0;
          }
          //update-end---author:zhangyafei    Date:20201118  for：适配不分页的数据列表------------
        } else {
          this.$message.warning(res.message)
        }
      }).finally(() => {
        this.loading = false
      })
    },
    initDictConfig() {
      console.log("--这是一个假的方法!")
    },
    handleSuperQuery(params, matchType) {
      //高级查询方法
      if (!params) {
        this.superQueryParams = ''
        this.superQueryFlag = false
      } else {
        this.superQueryFlag = true
        this.superQueryParams = JSON.stringify(params)
        this.superQueryMatchType = matchType
      }
      this.loadData(1)
    },
    getQueryParams() {
      //获取查询条件
      let sqp = {}
      if (this.superQueryParams) {
        sqp['superQueryParams'] = encodeURI(this.superQueryParams)
        sqp['superQueryMatchType'] = this.superQueryMatchType
      }
      var param = Object.assign(sqp, this.queryParam, this.isorter, this.filters);
      param.field = this.getQueryField();
      param.pageNo = this.ipagination.current;
      param.pageSize = this.ipagination.pageSize;
      return filterObj(param);
    },
    getQueryField() {
      //TODO 字段权限控制
      var str = "id,";
      this.columns.forEach(function (value) {
        str += "," + value.dataIndex;
      });
      return str;
    },

    onSelectChange(selectedRowKeys, selectionRows) {
      this.selectedRowKeys = selectedRowKeys;
      this.selectionRows = selectionRows;
    },
    onClearSelected() {
      this.selectedRowKeys = [];
      this.selectionRows = [];
      this.strSelectedRowKeys = '';
    },
    searchQuery() {
      this.loadData(1);
    },
    superQuery() {
      this.$refs.superQueryModal.show();
    },
    searchReset() {
      this.contractType = ''
      this.partnerName = ''
      this.queryParam = {}
      this.loadData(1);
    },
    truncateTable: function () {
      if (!this.url.truncateTable) {
        this.$message.error("请设置url.truncateTable属性!")
        return
      }
      var that = this;
      this.$confirm({
        title: "确认清空日志",
        content: "是否清空ws_log表数据?",
        onOk: function () {
          that.loading = true;
          getAction(that.url.truncateTable, {}).then((res) => {
            if (res.success) {
              //重新计算分页问题
              that.reCalculatePage(that.selectedRowKeys.length)
              that.$message.success(res.message);
              that.loadData();
            } else {
              that.$message.warning(res.message);
            }
          }).finally(() => {
            that.loading = false;
          });
        }
      });
    },
    batchDel: function () {
      if (!this.url.deleteBatch) {
        this.$message.error("请设置url.deleteBatch属性!")
        return
      }
      if (this.selectedRowKeys.length <= 0) {
        this.$message.warning('请选择一条记录！');
        return;
      } else {
        var ids = "";
        for (var a = 0; a < this.selectedRowKeys.length; a++) {
          ids += this.selectedRowKeys[a] + ",";
        }
        var that = this;
        this.$confirm({
          title: "确认删除",
          content: "是否删除选中数据?",
          onOk: function () {
            that.loading = true;
            deleteAction(that.url.deleteBatch, { ids: ids }).then((res) => {
              if (res.success) {
                //重新计算分页问题
                that.reCalculatePage(that.selectedRowKeys.length)
                that.$message.success(res.message);
                that.loadData();
                that.onClearSelected();
              } else {
                that.$message.warning(res.message);
              }
            }).finally(() => {
              that.loading = false;
            });
          }
        });
      }
    },
    handleDelete: function (id) {
      if (!this.url.delete) {
        this.$message.error("请设置url.delete属性!")
        return
      }
      var that = this;
      deleteAction(that.url.delete, { id: id }).then((res) => {
        if (res.success) {
          //重新计算分页问题
          that.reCalculatePage(1)
          that.$message.success(res.message);
          that.loadData();
        } else {
          that.$message.warning(res.message);
        }
      });
    },
    transferIntention: function (e) {
      if (!this.url.transferIntention) {
        this.$message.error("请设置url.deleteBatch属性!")
        return
      }
      if (this.selectedRowKeys.length <= 0) {
        this.$message.warning('请选择一条记录！');
        return;
      } else {
        var ids = "";
        for (var a = 0; a < this.selectedRowKeys.length; a++) {
          ids += this.selectedRowKeys[a] + ",";
        }
        var that = this;
        var context = "";
        if (e == "0") {
          context = "是否将选中数据从公海捞回?";
        }
        if (e == "1") {
          context = "是否将选中数据转为意向劳动者?";
        }
        if (e == "2") {
          context = "是否将选中数据放入公海?";
        }
        this.$confirm({
          title: "确认",
          content: context,
          onOk: function () {
            that.loading = true;
            deleteAction(that.url.transferIntention, { ids: ids, isConversion: e }).then((res) => {
              if (res.success) {
                //重新计算分页问题
                that.reCalculatePage(that.selectedRowKeys.length)
                that.$message.success(res.message);
                that.loadData();
                that.onClearSelected();
              } else {
                that.$message.warning(res.message);
              }
            }).finally(() => {
              that.loading = false;
            });
          }
        });
      }
    },
    reCalculatePage(count) {
      //总数量-count
      let total = this.ipagination.total - count;
      //获取删除后的分页数
      let currentIndex = Math.ceil(total / this.ipagination.pageSize);
      //删除后的分页数<所在当前页
      if (currentIndex < this.ipagination.current) {
        this.ipagination.current = currentIndex;
      }
      console.log('currentIndex', currentIndex)
    },
    handleEdit: function (record) {
      this.$refs.modalForm.edit(record);
      this.$refs.modalForm.title = "编辑";
      this.$refs.modalForm.disableSubmit = false;
    },
    handleAdd: function () {
      this.$refs.modalForm.add();
      this.$refs.modalForm.title = "新增";
      this.$refs.modalForm.disableSubmit = false;
    },
    handleTableChange(pagination, filters, sorter) {
      //分页、排序、筛选变化时触发
      //TODO 筛选
      console.log(pagination)
      if (Object.keys(sorter).length > 0) {
        this.isorter.column = sorter.field;
        this.isorter.order = "ascend" == sorter.order ? "asc" : "desc"
      }
      this.ipagination = pagination;
      this.loadData();
    },
    handleToggleSearch() {
      this.toggleSearchStatus = !this.toggleSearchStatus;
    },
    // 给popup查询使用(查询区域不支持回填多个字段，限制只返回一个字段)
    getPopupField(fields) {
      return fields.split(',')[0]
    },
    modalFormOk() {
      // 新增/修改 成功时，重载列表
      this.loadData();
      //清空列表选中
      this.onClearSelected()
    },
    /* 详情 */
    handleDetail: function (record) {
      this.$refs.modalForm.edit(record);
      this.$refs.modalForm.title = "详情";
      this.$refs.modalForm.disableSubmit = true;
    },
    /* 导出 */
    handleExportXls2() {
      let paramsStr = encodeURI(JSON.stringify(this.getQueryParams()));
      let url = `${window._CONFIG['domianURL']}/${this.url.exportXlsUrl}?paramsStr=${paramsStr}`;
      window.location.href = url;
    },
    handleExportXls(fileName) {
      if (!fileName || typeof fileName != "string") {
        fileName = "导出文件"
      }
      let param = this.getQueryParams();
      if (this.selectedRowKeys && this.selectedRowKeys.length > 0) {
        param['selections'] = this.selectedRowKeys.join(",")
      }
      console.log("导出参数", param)
      downFile(this.url.exportXlsUrl, param).then((data) => {
        if (!data) {
          this.$message.warning("文件下载失败")
          return
        }
        if (typeof window.navigator.msSaveBlob !== 'undefined') {
          window.navigator.msSaveBlob(new Blob([data], { type: 'application/vnd.ms-excel' }), fileName + '.xls')
        } else {
          let url = window.URL.createObjectURL(new Blob([data], { type: 'application/vnd.ms-excel' }))
          let link = document.createElement('a')
          link.style.display = 'none'
          link.href = url
          link.setAttribute('download', fileName + '.xls')
          document.body.appendChild(link)
          link.click()
          document.body.removeChild(link); //下载完成移除元素
          window.URL.revokeObjectURL(url); //释放掉blob对象
        }
      })
    },
    /* 导入 */
    handleImportExcel(info) {
      this.loading = true;
      if (info.file.status !== 'uploading') {
        console.log(info.file, info.fileList);
      }
      if (info.file.status === 'done') {
        this.loading = false;
        if (info.file.response.success) {
          // this.$message.success(`${info.file.name} 文件上传成功`);
          if (info.file.response.code === 201) {
            let { message, result: { msg, fileUrl, fileName } } = info.file.response
            let href = window._CONFIG['domianURL'] + fileUrl
            this.$warning({
              title: message,
              content: (<div>
                <span>{msg}</span><br />
                <span>具体详情请 <a href={href} target="_blank" download={fileName}>点击下载</a> </span>
              </div>
              )
            })
          } else {
            this.$message.success(info.file.response.message || `${info.file.name} 文件上传成功`)
          }
          this.loadData()
        } else {
          //TODO cg 换行展示
          this.$error({
            title: '提示',
            content: (
              <div id="modelError"></div>
            ),
            width: 600,
            okText: '确定',
            mask: false,
            onOk: () => {
            }
          })
          let htmlString = `<div>
              <b>${info.file.name}</b>
              <p>${info.file.response.message.replace(/(\\n)/g, '')}</p>
            </div>`
          setTimeout(() => {
            document.getElementById('modelError').innerHTML = htmlString
          }, 0);
          // this.$message.error(`${info.file.name} ${info.file.response.message}.`,10);
        }
      } else if (info.file.status === 'error') {
        this.loading = false;
        if (info.file.response.status === 500) {
          let data = info.file.response
          const token = Vue.ls.get(ACCESS_TOKEN)
          if (token && data.message.includes("Token失效")) {
            this.$error({
              title: '登录已过期',
              content: '很抱歉，登录已过期，请重新登录',
              okText: '重新登录',
              mask: false,
              onOk: () => {
                store.dispatch('Logout').then(() => {
                  Vue.ls.remove(ACCESS_TOKEN)
                  window.location.reload();
                })
              }
            })
          }
        } else {
          this.$message.error(`文件上传失败: ${info.file.msg} `);
        }
      }
    },
    /* 图片预览 */
    getImgView(text) {
      if (text && text.indexOf(",") > 0) {
        text = text.substring(0, text.indexOf(","))
      }
      return getFileAccessHttpUrl(text)
    },
    /* 文件下载 */
    // update--autor:lvdandan-----date:20200630------for：修改下载文件方法名uploadFile改为downloadFile------
    downloadFile(text) {
      if (!text) {
        this.$message.warning("未知的文件")
        return;
      }
      if (text.indexOf(",") > 0) {
        text = text.substring(0, text.indexOf(","))
      }
      let url = getFileAccessHttpUrl(text)
      window.open(url);
    },
    /**
     * 下载合同使用并且传参数如下
     * @param response
     * @param ids
     * @param type 0-模版下载全部  1-合同下载全部 2-多选下载
     */
    downLoadPdf(text, type, fileType, ids) {
      if (fileType == "标准协议") {
        this.$message.warning("标准协议请到合作商合同下载！")
        return;
      }
      if (!text) {
        this.$message.warning("未知的文件")
        return;
      }
      if (ids == null || ids == "") {
        this.$message.warning("请选择下载文件!")
        return;
      }
      if (text.indexOf(",") > 0) {
        text = text.substring(0, text.indexOf(","))
      }
      let url = text + "?ids=" + ids + "&type=" + type;
      window.open(url);
    },
    handleTransfRule(id) {
      if (id == null || id == "") {
        this.$message.warning("请选择转换数据!")
        return;
      }
      // this.loading = true;
      this.$confirm({
        title: "转换规则",
        content: "确认转换规则吗?",
        onOk: () => {
          this.loading = true;
          getAction(this.url.transfRuleUrl, { id: id }).then((res) => {
            if (res.success) {
              this.loading = false;
              //重新计算分页问题
              this.reCalculatePage(1)
              this.$message.success(res.message);
              this.loadData();
            } else {
              this.loading = false;
              //TODO cg 换行展示
              this.$error({
                title: '提示',
                content: (
                  <div id="modelError"></div>
                ),
                width: 600,
                okText: '确定',
                mask: false,
                onOk: () => {
                }
              })
              let htmlString = `<div>
                <p>${res.message.replace(/(\\n)/g, '')}</p>
              </div>`
              setTimeout(() => {
                document.getElementById('modelError').innerHTML = htmlString
              }, 0);

              //that.$message.warning(res.message);
            }
          });
        }
      });


    },
    /**
     * 批量合同审核
     * @param response
     * @param ids
     */
    requestServer(apiUrl) {
      if (this.selectedRowKeys.length <= 0) {
        this.$message.warning('请选择一条合同！');
        return;
      } else {
        var ids = "";
        for (var a = 0; a < this.selectedRowKeys.length; a++) {
          ids += this.selectedRowKeys[a] + ",";
        }
        var that = this;
        this.$confirm({
          title: "确认审批合同",
          content: "是否审批选中合同?",
          onOk: function () {
            that.loading = true;
            // debugger;
            if (apiUrl != null) {
              if (apiUrl == "createFlyBookExamineBatch") {
                apiUrl = that.url.createFlyBookExamineBatch;
              } else if (apiUrl == "createDingTalkExamineBatch") {
                apiUrl = that.url.createDingTalkExamineBatch;
              } else {
                apiUrl = that.url.createExamineBatch;
              }
            } else {//apiUrl为null，默认走微信
              apiUrl = that.url.createExamineBatch;
            }
            postAction(apiUrl, { ids: ids }).then((res) => {
              if (res.success) {
                //重新计算分页问题
                that.reCalculatePage(that.selectedRowKeys.length)
                that.$message.success(res.message);
                that.loadData();
                that.onClearSelected();
              } else {
                that.$message.warning(res.message);
              }
            }).finally(() => {
              that.loading = false;
            });
          }
        });
      }
    },

    /**
     * 同步飞书数据用户
     * @param response
     * @param ids
     */
    syncFeiShuDepartToLocal() {
      var that = this;
      this.$confirm({
        title: "确认同步飞书数据用户",
        content: "是否同步飞书数据用户?",
        onOk: function () {
          that.loading = true;
          postAction(that.url.syncFeiShuDepartToLocal, null).then((res) => {
            if (res.success) {
              //重新计算分页问题
              that.reCalculatePage(that.selectedRowKeys.length)
              that.$message.success(res.message);
              that.loadData();
              that.onClearSelected();
            } else {
              that.$message.warning(res.message);
            }
          }).finally(() => {
            that.loading = false;
          });
        }
      });
    },
    /**
     * 同步钉钉数据用户
     * @param response
     * @param ids
     */
    syncDingTalkDepartToLocal() {
      var that = this;
      this.$confirm({
        title: "确认同步钉钉数据用户",
        content: "是否同步钉钉数据用户?",
        onOk: function () {
          that.loading = true;
          postAction(that.url.syncDingTalkDepartToLocal, null).then((res) => {
            if (res.success) {
              //重新计算分页问题
              that.reCalculatePage(that.selectedRowKeys.length)
              that.$message.success(res.message);
              that.loadData();
              that.onClearSelected();
            } else {
              that.$message.warning(res.message);
            }
          }).finally(() => {
            that.loading = false;
          });
        }
      });
    },

    /**
     * 单个合同审核
     * @param response
     * @param ids
     */
    requestServerOne(record) {
      if (record == null) {
        this.$message.warning('请选择一条合同！');
        return;
      } else {
        var ids = "";
        ids = record.id + ",";
        var that = this;
        this.$confirm({
          title: "确认审批合同",
          content: "是否审批" + record.contractName + "此合同?",
          onOk: function () {
            that.loading = true;
            postAction(that.url.createExamineBatch, { ids: ids }).then((res) => {
              if (res.success) {
                //重新计算分页问题
                that.reCalculatePage(that.selectedRowKeys.length)
                that.$message.success(res.message);
                that.loadData();
                that.onClearSelected();
              } else {
                that.$message.warning(res.message);
              }
            }).finally(() => {
              that.loading = false;
            });
          }
        });
      }
      if (text.indexOf(",") > 0) {
        text = text.substring(0, text.indexOf(","))
      }
      let url = text + "?ids=" + ids + "&type=" + type;
      window.open(url);
    },

    /**
     * 下载url数据
     * @param url
     */
    downLoadExcel(url) {
      if (url == null) {
        this.$message.warning("url为空！！!")
        return;
      } else {
        window.open(url);
      }
    },
    downloaDcontractTemplate(fileType) {
      let fileUrl = null;
      // debugger;
      if (fileType == 0) {
        fileUrl = "https://hl-picture.oss-cn-beijing.aliyuncs.com/templateFile/框架协议模板.xlsx"
      } else if (fileType == 1) {
        fileUrl = "https://hl-picture.oss-cn-beijing.aliyuncs.com/templateFile/附加协议模板.xlsx"
      } else if (fileType == 2) {
        fileUrl = "https://hl-picture.oss-cn-beijing.aliyuncs.com/templateFile/标准价格模板.xlsx"
      } else if (fileType == 3) {
        fileUrl = "https://hl-picture.oss-cn-beijing.aliyuncs.com/templateFile/甲方附加协议模板.xlsx"
      } else if (fileType == 4) {
        fileUrl = "https://hl-picture.oss-cn-beijing.aliyuncs.com/templateFile/附加协议模板-对赌多阶梯.xlsx?"+Math.random()+""
      } else {
        this.$message.warning("类型有问题！！")
        return
      }
      window.open(fileUrl);
    },

  }

}